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Technical Field 

The present invention relates generally to computer systems, and more particularly 
to a system and method to enable communications between one or more (e.g., managed to 
unmanaged) object systems, including in-lined stub functionality employed to facilitate 
1 0 operational performance and communications between the object systems. 

RarkgroifnH nf tht> Invention 

As computer science has evolved, object oriented programming has become one 
of many familiar models designers and programmers utilize to implement functionality 

1 5 within computer systems. The object model generally is defined by a class structure that 
includes class members providing both methods and associated data elements belonging 
to the class. The class members thus provide/define desired functionality within a 
computer program, wherein an object is declared as an instance of a particular class. As 
is commonplace, objects often must exchange data and/or invoke other objects operating 

20 on the same platform and/or communicate with objects belonging to remote platforms. In 

order to communicate between objects, interface systems and standards have been 
developed to define how objects may communicate and/or interact with one another. 

A familiar system for communicating and interfacing between objects is known as 
the Component Object Model (COM), wherein another similar system is referred to as the 
25 Common Object Request Brokers Architecture (CORBA). Still yet other communication 
interfaces may be defined in languages such as JAVA within an operating framework of a 
Java Virtual Machine, for example. As these and other systems have been developed 
however, two common object architectures or models generally have emerged and may 
generally be defined in terms of managed and unmanaged object systems, for example. 

30 Managed objects may be allocated from a heap within a managed software 

environment and are generally not responsible for managing associated object lifetimes. 
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Managed objects may be described in terms of a data type (e.g., metadata) and 
automatically collected {e.g., reclaimed) by a managed environment "garbage collector" 
that removes the object from memory when the object is no longer being accessed. In 
contrast, unmanaged objects may be allocated from a standard operating system heap, 
5 wherein the object itself is responsible for freeing memory it employs when references to 

the object no longer exist. This may be accomplished through well-known techniques 
such as reference counting, for example. 

Managed applications and/or objects can execute calls to unmanaged Application 
Program Interfaces (APIs) (e.g., operating system APIs, entry points into dynamically 

1 0 loaded dynamic link libraries (DLLs), entry points into COM components) by a process 
called "platform invoke." In general, a call from managed to unmanaged code requires 
some additional code to be executed as part of a transition between the two execution 
models. For example, this may entail: potentially marshalling a plurality of arguments 
and return values (e.g., depending on the actual data-type, some data-types may not have 

1 5 similar representations in managed and unmanaged code); locating multiple markers on 

an execution stack (e.g., in order that a managed system can locate "managed" and 
"unmanaged" segments of the execution stack); considering thread execution on return 
from unmanaged to managed code; and potentially managing security issues between the 
execution environments. 

20 In a general situation, this can be implemented by directing the call through an 

external interface referred to as "stub-code" that can perform these operations. 
Unfortunately, one or more of these stub-code operations are particularly time intensive 
(e.g., as compared to a regular call of a function in the same object system). For example, 
by utilizing a call through the stub, stack-based arguments often need to be copied onto a 

25 different stack location (i.e., the arguments need to be pushed again) - even if marshalling 

for the actual data-types is unnecessary. Another problem relates to adding markers on 
the stack and can involve an explicit update of a linked list, for example, such that access 
to the root of that list is comparatively expensive (e.g., processor execution cycles). Due 
to these and other issues relating to communications between object systems, there is a 

30 need for a system and methodology to facilitate improved execution performance when 
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invoking functions and/or objects between object systems. 

Summary of the Invention 

The following presents a simplified summary of the invention in order to provide 

5 a basic understanding of some aspects of the invention. This summary is not an extensive 

overview of the invention. It is intended to neither identify key or critical elements of the 
invention nor delineate the scope of the invention. Its sole purpose is to present some 
concepts of the invention in a simplified form as a prelude to the more detailed 
description that is presented later. 

1 0 The present invention relates to a system and methodology that facilitates 

communications and execution performance between managed and unmanaged code 
environments. This is achieved by providing functional aspects and considerations of an 
in-lined stub having portions thereof incorporated within the execution framework of a 
calling function between managed and unmanaged code - in lieu of calling an external 

1 5 interface stub at run time. In this manner, copying and/or re-pushing of outgoing 

functional arguments onto an execution stack are mitigated. Moreover, adding a stack 
marker, for example, to an explicit list of stack markers can be hoisted (e.g., separated 
from an actual call). Thus, in the case of multiple calls, the list can be updated a single 
time instead of providing an update to the list each time for respective call sites. In 

20 addition, the in-lined stub mitigates the need to marshal outgoing call arguments and 

return values, and reduces the need for runtime security checking between the managed 
and unmanaged environments. 

In accordance with the present invention, a caller is provided having optimized in- 
lined functionality when initiating a remote function call between managed and 

25 unmanaged object systems. The in-lined functionality includes utilizing direct calls and 

returns within a calling function. In this manner, pushing additional arguments onto an 
execution stack because of an external stub reference is reduced. According to another 
aspect of the present invention, code loops are analyzed to enable stack markers to be 
"hoisted" and thus pushed a single time instead of each time the calling function 

30 executes. Other aspects of the optimized caller provide garbage collection and thread 
management, security attribute checking on outgoing calls, and calling convention 
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considerations, wherein arguments and return values are organized according to the 
convention utilized by the remote object system. In-lined marshalling can be included to 
provide enhanced performance over external stub code references along with code 
extensibility options wherein, functions can be generalized to insulate respective object 

5 systems from implementation details of the called functions. 

The following description and the annexed drawings set forth in detail certain 
illustrative aspects of the invention. These aspects are indicative, however, of but a few 
of the various ways in which the principles of the invention may be employed and the 
present invention is intended to include all such aspects and their equivalents. Other 

1 0 advantages and novel features of the invention will become apparent from the following 

detailed description of the invention when considered in conjunction with the drawings. 

Rrief Descr iption of the Drawings 

Fig. 1 is a schematic block diagram illustrating an optimized caller with in-lined 
1 5 code in accordance with an aspect of the present invention. 

Fig. 2 is a diagram illustrating direct call and return functionality in accordance 
with an aspect of the present invention. 

Fig. 3 is a diagram illustrating hoisting and synchronization management in 
accordance with an aspect of the present invention. 
20 Fig. 4 is a diagram illustrating garbage collection and thread management in 

accordance with an aspect of the present invention. 

Fig. 5 is a diagram illustrating in-lined security attribute checking in accordance 
with an aspect of the present invention. 

Fig. 6 is a flow diagram illustrating calling convention management in accordance 
25 with an aspect of the present invention. 

Fig. 7 is a flow diagram illustrating in-lined marshalling in accordance with an 

aspect of the present invention. 

Fig. 8 is a diagram illustrating interface extensibility in accordance with an aspect 

of the present invention. 

30 Fig. 9 is a schematic block diagram illustrating a suitable operating environment 

in accordance with an aspect of the present invention. 
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retailed Desc ription of the Invention 

The present invention relates to a system and methodology to facilitate 
communications and enhanced processor execution performance between object systems. 
5 Although the present invention is described in terms of communications between 

managed and unmanaged object systems, it is to be appreciated that the concepts, as 
described herein, can be utilized to include communications between substantially any 
object system (e.g., managed/unmanaged, managed/managed, unmanaged/unmanaged 
object systems). 

1 o The present invention promotes enhanced computer execution performance via a 

general performance optimization for interoperation of code that can be under the control 
of an execution engine, virtual machine and/or other code such as unmanaged code. In 
order to minimize the execution overhead for the transition between object systems 
during communications, the present invention includes one or more optimizations within 
1 5 a calling function that facilitates communications between the object systems (e.g., 

managed to unmanaged code). According to one aspect of the present invention, a 
plurality of conditions can be controlled which can be statically or dynamically validated 
at code generation time (e.g., Just-In-Time (JIT) and/or "Pre-JIT"), wherein interface 
code can be in-lined into a caller in order to "speed-up" the overall execution time of a 
20 call/return pair across a managed/unmanaged boundary. Several factors can contribute to 

the speed-up during object system communications. For example, copying (e.g., re- 
pushing) of outgoing call arguments is mitigated and adding a stack marker to an explicit 
list of stack markers can be hoisted. In cases including multiple calls, for example, 
adding to the list can be achieved in a single update instead of multiple updates as with 
25 conventional systems. 

Referring initially to Fig. 1, a system 10 illustrates communications between 
object systems in accordance with an aspect of the present invention. A boundary line 20 
depicts a separation between a managed and unmanaged operating environment, wherein 
an optimized caller 30 is provided to facilitate communications between a managed 
30 application 34 and an unmanaged function and/or object 38. It is noted that one or more 

callers (not shown) can be included within the managed application 34 and are invoked 
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when methods and/or function calls are initiated from the managed application 34, 
wherein respective methods and/or function calls can be associated with a caller other 
than the caller 30. The caller 30 incorporates stub functional portions 42 (illustrated for 
explanatory purposes only) within the caller 30 to improve code execution performance in 
5 accordance with the present invention. 

As illustrated, the caller 30 utilizes a direct call/return pair 44 and 46 to interact 
and communicate with the unmanaged object 38 rather than invoke an external stub (not 
shown) as with conventional systems. In this manner, stack operations such as pushing 
and popping arguments and return values related to the external stub are reduced thus 

1 0 conserving processor execution cycles. In accordance with another aspect of the present 
invention, a hoisting operation 50 can be provided that further mitigates code execution 
cycles. As will be described in more detail below, the hoisting operation 50 involves 
locating a stack marker (not shown) that is utilized for the return 46 from the unmanaged 
object 38. This is an optimization, wherein the stack marker is located outside of a code 

1 5 loop and placed a single time onto a return list, for example, rather than being 
placed/located each time the caller 30 executes as with conventional systems. 

Due to the hoisting operation 50, several issues involving timing and 
synchronization of the call/return pair 44 and 46 between the managed and unmanaged 
environment are considered and accounted for that are generally not required of 

20 conventional systems. As will be described in more detail below, this can include 

providing one or more synchronization flags within the caller 30 to facilitate the hoisting 
operation 50. This can also include providing garbage collection and/or thread 
management code 52 to further account for these issues. 

Other aspects of the present invention can include providing in-lined security 

25 attribute checking 54 within the caller 30, wherein permissions can be verified as to 
whether the caller 30 can invoke the unmanaged object 38. A calling convention 
management aspect 56 can also be provided that enables the caller 30 to organize call and 
return arguments according to the convention utilized by the unmanaged object 38. 
Another aspect includes optional inline marshalling 58 within the caller 30. This can 

30 include incorporation of data marshalling code within the caller 30 depending on desired 



6 



'MS 174295.1 

system performance requirements. Still yet another aspect of the present invention 
includes providing extensibility 60 to the caller 30. As will be described in more detail 
below, this can include generalizing functional calls to the unmanaged object 38 such that 
implementation details within the calls are insulated from the caller 30 and the 
5 unmanaged obj ect 3 8 . 

Figs. 2 through 8 illustrate one or more methodologies (Figs. 2, 3, 4, 5 and 8 also 
have respective system/other diagrams) to facilitate communications between object 
systems in accordance with the present invention. While, for purposes of simplicity of 
explanation, the methodologies are shown and described as a series of acts, it is to be 
1 0 understood and appreciated that the present invention is not limited by the order of acts, 
as some acts may, in accordance with the present invention, occur in different orders 
and/or concurrently with other acts from that shown and described herein. For example, 
those skilled in the art will understand and appreciate that a methodology could 
alternatively be represented as a series of interrelated states or events, such as in a state 
1 5 diagram. Moreover, not all illustrated acts may be required to implement a methodology 

in accordance with the present invention. 

Referring now to Fig. 2, a flow diagram 100 and calling function 1 10 illustrate 
direct call and return functionality in accordance with an aspect of the present invention. 
At 1 14, indirect calls and stacking operations that were formerly directed to an external 
20 stub are removed from a calling function. At 1 1 8, direct call, return and stack operations 
are incorporated within a calling function 1 1 0, wherein the calling function 1 1 0 can call 
and manage returns from unmanaged code directly without invoking an external stub 
interface, for example. This improves code execution efficiency over conventional 
systems, wherein argument pushing and popping operations occurred for both the indirect 
25 call to the external stub but, also for the external stub interface operations to unmanaged 

code. 

The calling function 110, illustrates the direct call and return management aspects 
of the present invention. At 120, arguments associated with the calling function are 
pushed onto an execution stack (not shown). These arguments, {e.g., pointers, variables) 
30 can include variable and other parameters that are utilized by the managed system and the 
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remote object/function during execution/return of the call. At 124, a call is directed to the 
unmanaged code from the calling function 1 1 0. After the unmanaged code executes the 
remote call, a return is initiated by the unmanaged code and is illustrated at 1 28. At 1 32, 
return arguments provided from the unmanaged code at 124 are popped from the stack to 
5 complete the call. This may also include popping a stack marker to direct the calling 

function 1 10 back within the managed code from which the call originated. 

Turning now to Fig. 3, a flow diagram 200 and caller 210 illustrate hoisting and 
synchronization management in accordance with an aspect of the present invention. At 
214, managed code is analyzed (e.g., during compiler optimization routine) to determine 
1 0 where calls originate from such as within a loop or nested loop sequence of code. From 
this analysis, a stack marker operation such as illustrated at 220, is hoisted or removed at 
224 out of the loop and placed in operable association with the caller 210 (e.g., placed at 
a lower or higher stack address relative to the caller 210). In this manner, the stack 
marker and related operation 220 can occur a single time per the caller 210 as opposed to 
1 5 each time the caller executes within a loop. As can be appreciated, this also conserves 
processor and code execution cycles. 

Due to the hoisting operation at 224, other issues relating to synchronization and 
timing of a call/return pair between managed and unmanaged code are considered. For 
example, when the stack marker 220 is hoisted at 224, there is no longer substantial 
20 certainty that execution has transitioned from the managed environment to the 

unmanaged environment. This is a concern for such issues as operating with a managed 
garbage collector during unmanaged call execution, for example, and is described in more 
detail below. Thus, at 228, transition code is added to the calling function to manage 
synchronization at 232 between the execution of the caller 210, and a system manager 
25 such as a garbage collector that is concerned with the lifetime of the caller 210 and the 

area of memory in which the caller 210 exists. Therefore, one or more flags 240 are 
associated with the caller 210 to enable synchronization management between object 
systems during code execution transitions. This can include timing and consideration of 
such conditions (e.g., race conditions) that can occur between setting the one or more 
30 flags 240 indicating a transition from managed execution to unmanaged execution and 
vice versa and the actual transition that may occur at a different point in time. Other 



8 



*MS 174295.1 

considerations involve the timing of the garbage collector and thread execution upon calls 
and returns between managed and unmanaged code. Also depicted with the caller 210 are 
related arguments and return addresses 248. 

Referring now to Fig. 4, a system 300 and flow diagram 310 illustrate garbage 
5 collection and thread management in accordance with an aspect of the present invention. 

The system 300 includes a caller 314 and unmanaged code 318 for executing calls 322 
and returns 324 in accordance with the present invention. Proceeding to the flow diagram 
310, garbage collector test code is generated at 330 that can include the acts illustrated in 
310. Thus, functionality is incorporated into the caller 314 that provide operative 
1 0 instructions to interact with the garbage collector. This includes considerations such as 

whether the garbage collector (not shown) is just about to execute or is currently 
executing since caller execution threads associated with the caller 314 can be suspended 
during garbage collector operations. For example, a global flag can be adjusted and/or 
periodically updated in the background (e.g., set/reset) relating to the state of the garbage 
1 5 collector before and/or during the call 322. Upon the return 324 from the unmanaged 

code 3 1 8, a determination is made at 338 concerning the current state of the garbage 
collector. If the garbage collector is operating at 338, (e.g., determined from flag 
provided at 334 or other indication) the process proceeds to 342 wherein return 
operations are suspended until the garbage collector has completed activities. If the 
20 garbage collector has completed operations at 338, the process proceeds to 348 and resets 

flags associated therewith and then proceeds to return arguments at 352 to the caller 314. 

Referring now to Fig. 5, a caller 400 and flow diagram 410 illustrate inline 
security attribute checking in accordance with an aspect of the present invention. 
Proceeding to the flow diagram 410, inline security code is generated at 420 that can 
25 include the acts illustrated in 4 1 0. This can involve providing code that determines 

security rights and/or other policies between the caller 400 and the unmanaged code (not 
shown). For example, attributes can be provided that are associated with the unmanaged 
code that determine whether or not the caller 400 can access and/or utilize the unmanaged 
code. Providing this type of checking inline with the caller 400 enables an optimization, 
30 wherein the managed and unmanaged environments are insulated from the management 
details of the other environments execution restrictions. At 424, for example, a 
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determination is made as to whether a called function has suitable security rights to 
enable remote execution from the caller 400. This can include checking/comparing 
security attributes (e.g., passed as a stack argument, provided in a global file) associated 
with the unmanaged code. If the security attributes are in agreement with the caller at 
5 424, the process proceeds to 430, wherein the call is then executed with the unmanaged 

code. If the security attributes are not in agreement at 424, the call can be returned at 434 
as an exception (e.g., error flag/code/interrupt), for example, to the caller 400. 

Referring to Fig. 6, a methodology 500 illustrates calling convention management 
in accordance with an aspect of the present invention. As one or more of the aspects 

1 0 previously described (e.g., callers, management code) can be invoked/constructed with a 

code generator such as a Just-In-Time (JIT) or Pre-JIT compiler at run time, the nature 
and orderings of the remote calling conventions employed by the unmanaged code are 
considered. For example, at 504, these conventions are determined according to the 
specifications of the unmanaged code and/or remote object system. This can include 

1 5 organizing and/or aligning arguments and the stack, for example, according to the format 

and structure (e.g., ordering of execution stack, variable structure, argument ordering) 
expected by the remote object system at 508. At 512, a call is directed to unmanaged 
code after organizing and providing arguments according to the unmanaged convention or 
format. At 5 1 6, return values are interpreted and managed by the caller according to the 

20 calling convention determined at 504. 

Referring now to Fig. 7, a flow diagram 550 illustrates an aspect of inline 
marshalling in accordance with an aspect of the present invention. This includes 
performing a tradeoff analysis between execution performance and code size. For 
example, marshalling code can cause a substantial amount of code to be generated inline 

25 with a caller (not shown). However, call execution performance can be improved by 

providing in-lined marshalling code as opposed to calling an external function to provide 
data marshalling between the managed and unmanaged environments. Thus, at 554, 
system performance requirements are considered. If performance aspects outweigh the 
additional code aspects at 556, the process proceeds to 560 and generates in-lined 

30 marshalling code before proceeding with an unmanaged call utilizing the in-lined 

marshalling code at 564. If the performance aspects do not outweigh the code generation 
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aspects at 556, the process proceeds to 570, wherein external marshalling code is utilized 
during a call to unmanaged code. 

Turning to Fig. 8, a diagram 600 illustrates interface extensibility in accordance 
with an aspect of the present invention. This includes generalizing the calling convention 
5 between the managed and unmanaged code at 604 to enable the object systems to be 

insulated from implementation details such as structural differences between the systems 
(e.g., argument signatures, variable details, code differences). An exemplary calling 
convention is illustrated at 608, wherein, unmanaged Functions 1 though X are provided, 
the functions including arguments 1 though L, 1 through M, and 1 through N, 
1 0 respectively, X, L, M, and N being integers. At 61 2, extensibility is provided to the 

calling function. This is illustrated at 616, wherein a "function pointer" is declared for 
example, passing as an argument the desired unmanaged function to execute. As an 
example, if a calling function "A" were coded to execute an unmanaged function (2), or 
any function number having an unmanaged corollary, the code can appear as "A = 
1 5 func _ptr (F(2, args)" thus, enabling the caller to call substantially any function having the 
proposed format illustrated at 616, without regard for the actual implementation code of 
the remote and/or unmanaged code. 

In order to provide a context for the various aspects of the invention, Fig. 9 and 
the following discussion are intended to provide a brief, general description of a suitable 
20 computing environment in which the various aspects of the present invention may be 

implemented. While the invention has been described above in the general context of 
computer-executable instructions of a computer program that runs on a computer and/or 
computers, those skilled in the art will recognize that the invention also may be 
implemented in combination with other program modules. Generally, program modules 
25 include routines, programs, components, data structures, etc. that perform particular tasks 

and/or implement particular abstract data types. Moreover, those skilled in the art will 
appreciate that the inventive methods may be practiced with other computer system 
configurations, including single-processor or multiprocessor computer systems, 
minicomputers, mainframe computers, as well as personal computers, hand-held 
30 computing devices, microprocessor-based or programmable consumer electronics, and 
the like. The illustrated aspects of the invention may also be practiced in distributed 
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computing environments where tasks are performed by remote processing devices that are 
linked through a communications network. However, some, if not all aspects of the 
invention can be practiced on stand-alone computers. In a distributed computing 
environment, program modules may be located in both local and remote memory storage 
5 devices. 

With reference to Fig. 9, an exemplary system for implementing the various 
aspects of the invention includes a computer 720, including a processing unit 721, a 
system memory 722, and a system bus 723 that couples various system components 
including the system memory to the processing unit 721. The processing unit 72 1 may 
10 be any of various commercially available processors. It is to be appreciated that dual 

microprocessors and other multi-processor architectures also may be employed as the 
processing unit 721 . 

The system bus may be any of several types of bus structure including a memory 
bus or memory controller, a peripheral bus, and a local bus using any of a variety of 

1 5 commercially available bus architectures. The system memory may include read only 

memory (ROM) 724 and random access memory (RAM) 725. A basic input/output 
system (BIOS), containing the basic routines that help to transfer information between 
elements within the computer 720, such as during start-up, is stored in ROM 724. 

The computer 720 further includes a hard disk drive 727, a magnetic disk drive 

20 728, e.g., to read from or write to a removable disk 729, and an optical disk drive 730, 

e.g., for reading from or writing to a CD-ROM disk 73 1 or to read from or write to other 
optical media. The hard disk drive 727, magnetic disk drive 728, and optical disk drive 
730 are connected to the system bus 723 by a hard disk drive interface 732, a magnetic 
disk drive interface 733, and an optical drive interface 734, respectively. The drives and 

25 their associated computer-readable media provide nonvolatile storage of data, data 

structures, computer-executable instructions, etc. for the computer 720. Although the 
description of computer-readable media above refers to a hard disk, a removable 
magnetic disk and a CD, it should be appreciated by those skilled in the art that other 
types of media which are readable by a computer, such as magnetic cassettes, flash 

30 memory cards, digital video disks, Bernoulli cartridges, and the like, may also be used in 
the exemplary operating environment, and further that any such media may contain 
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computer-executable instructions for performing the methods of the present invention. 

A number of program modules may be stored in the drives and RAM 725, 
including an operating system 735, one or more application programs 736, other program 
modules 737, and program data 738. It is noted that the operating system 735 in the 
5 illustrated computer may be substantially any suitable operating system. 

A user may enter commands and information into the computer 720 through a 
keyboard 740 and a pointing device, such as a mouse 742. Other input devices (not 
shown) may include a microphone, a joystick, a game pad, a satellite dish, a scanner, or 
the like. These and other input devices are often connected to the processing unit 721 
1 0 through a serial port interface 746 that is coupled to the system bus, but may be connected 
by other interfaces, such as a parallel port, a game port or a universal serial bus (USB). A 
monitor 747 or other type of display device is also connected to the system bus 723 via an 
interface, such as a video adapter 748. In addition to the monitor, computers typically 
include other peripheral output devices (not shown), such as speakers and printers. 
1 5 The computer 720 may operate in a networked environment using logical 

connections to one or more remote computers, such as a remote computer 749. The 
remote computer 749 may be a workstation, a server computer, a router, a peer device or 
other common network node, and typically includes many or all of the elements described 
relative to the computer 720, although only a memory storage device 750 is illustrated m 
20 Fig. 9. The logical connections depicted in Fig. 9 may include a local area network 

(LAN) 751 and a wide area network (WAN) 752. Such networking environments are 
commonplace in offices, enterprise-wide computer networks, Intranets and the Internet. 

When employed in a LAN networking environment, the computer 720 maybe 
connected to the local network 751 through a network interface or adapter 753. When 
25 utilized in a WAN networking environment, the computer 720 generally may include a 
modem 754, and/or is connected to a communications server on the LAN, and/or has 
other means for establishing communications over the wide area network 752, such as the 
Internet. The modem 754, which may be internal or external, may be connected to the 
system bus 723 via the serial port interface 746. In a networked environment, program 
30 modules depicted relative to the computer 720, or portions thereof, may be stored in the 
remote memory storage device. It will be appreciated that the network connections 
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shown are exemplary and other means of establishing a communications link between the 
computers may be employed. 

In accordance with the practices of persons skilled in the art of computer 
programming, the present invention has been described with reference to acts and 

5 symbolic representations of operations that are performed by a computer, such as the 
computer 720, unless otherwise indicated. Such acts and operations are sometimes 
referred to as being computer-executed. It will be appreciated that the acts and 
symbolically represented operations include the manipulation by the processing unit 721 
of electrical signals representing data bits which causes a resulting transformation or 

1 0 reduction of the electrical signal representation, and the maintenance of data bits at 

memory locations in the memory system (including the system memory 722, hard drive 
727, floppy disks 729, and CD-ROM 73 1) to thereby reconfigure or otherwise alter the 
computer system's operation, as well as other processing of signals. The memory 
locations wherein such data bits are maintained are physical locations that have particular 

1 5 electrical, magnetic, or optical properties corresponding to the data bits. 

What has been described above are preferred aspects of the present invention. It 
is, of course, not possible to describe every conceivable combination of components or 
methodologies for purposes of describing the present invention, but one of ordinary skill 
in the art will recognize that many further combinations and permutations of the present 
20 invention are possible. Accordingly, the present invention is intended to embrace all such 
alterations, modifications and variations that fall within the spirit and scope of the 
appended claims. 
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